草庐IT

xml - DocBook:指定代码或标记

全部标签

ruby - 在 Xcode 运行脚本构建阶段使用 rvm 强制指定 Ruby

在Xcode之外,我使用特定版本的Ruby,使用RVM管理多个Ruby安装。Apple的命令行开发工具将Ruby安装在/usr/bin/ruby并且版本为1.8.7。我通过RVM使用1.9.3。有没有办法强制Xcode在运行其运行脚本构建阶段时使用我的1.9.3安装?我已经尝试将Shell路径设置为我的特定Ruby的完整路径,但这似乎没有什么不同,我的意思是我在1.9.3中安装的特定Gems不可用/在Xcode中运行时对脚本可见。如果我在命令行上通过xcodebuild运行我的项目,运行脚本阶段会使用我的特定Ruby,因为它是从我的shell环境中运行的(即使项目文件中的Shell路径

ruby - 哪些方法可以访问源代码?

有几种方法可以从需要/加载该库的Ruby代码中访问该库的源代码。在这些方式中,有的直接读取库文件并解析。其他人通过一些内置的方法访问源代码,这些方法提供有关源代码的信息(例如抽象语法树)。在我无法直接读取文件内容的情况下(如以前的方式),访问源代码的唯一方法是访问提供信息的内置方法。通过重新定义这些方法来做其他事情,我将完全失去对源代码的访问权限。最少的方法集是什么,如果我将它们重新定义为其他东西,我将完全失去对外部文件上库源代码的访问权限?重新表述问题假设:有一个用户可以在文件A中编写任何Ruby代码。有一个我写的静态Ruby文件B,它加载了文件A并调用了A中定义的主例程,还定义了一

ruby-on-rails - 如何在不渲染的情况下从 ERB 代码块中产生?

考虑以下几点:view.html.erb:stressedhelper.rb:defmake_backwardsyield.reverseendView呈现stresseddesserts而不仅仅是desserts。如何在不渲染代码块的情况下使用yield中的内容? 最佳答案 ERB有一个内部缓冲区,这使得block的使用有点复杂,正如您在代码示例中看到的那样。Rails提供了一个capture方法,它允许您在此缓冲区中捕获字符串并从block中返回它。因此您的助手将变成以下内容:defmake_backwardscapturedo

用于捕获正则表达式匹配项的 Ruby 单行代码

在Perl中,我使用以下一行语句通过正则表达式从字符串中提取匹配项并分配它们。这个找到一个匹配项并将其分配给一个字符串:my$string="thequickbrownfoxjumpsoverthelazydog.";my$extractString=($string=~m{fox(.*?)dog})[0];结果:$extractString=='jumpsoverthelazy'这个从多个匹配项创建一个数组:my$string="thequickbrownfoxjumpsoverthelazydog.";my@extractArray=$string=~m{the(.*?)fox.*

ruby - 如何确定指定方法源自哪个类?

我从thisdiscussion得到了这个问题.像object.m这样的方法调用并不总是意味着“object”类有一个“m”方法,就像对Array对象的find方法不是直接来自Array对象,而是来自混入的Enumerable模块。我的问题是,给定一个方法,我们如何确定该方法源自哪个类? 最佳答案 任何类/对象方法在Ruby中都是一个对象,并且有一些它自己的方法。所以你可以这样做:[].method(:count).inspect=>"#"[].method(:detect).inspect=>"#"快速使用RegEx,您就完成了。

ruby - 作为开发人员,不同的 Ruby 线程模型(Ruby 与 JRuby)对您的代码有什么实际影响?

我试图了解MRIRuby1.8和JRuby之间不同线程模型的实际影响。作为开发者,这种差异对我意味着什么?另外,MRIRuby1.8中是否有任何实际代码示例会由于不同的线程模型而在JRuby上具有更差的性能特征? 最佳答案 状态ruby1.8有绿色线程,这些线程可以快速创建/删除(作为对象)但不是真正的并行执行,甚至不由操作系统调度,而是由虚拟机调度ruby1.9有真正的线程,由于操作系统调用,创建/删除(作为对象)很慢,但由于GIL(全局解释器锁)一次只允许一个线程执行,所以这些都不是真正的线程并行JRuby也有操作系统调度的真实

Ruby:在代码中使用 rand() 但编写测试来验证概率

我有一些代码可以根据加权随机数提供内容。权重越大的东西越有可能被随机选择。现在作为一名优秀的ruby​​ist,我当然想用测试覆盖所有这些代码。我想测试是否根据正确的概率获取了东西。那么我该如何测试呢?为应该是随机的东西创建测试使得很难比较实际与预期。我有一些想法,以及为什么它们不会很好地工作:在我的测试中stubKernel.rand以返回固定值。这很酷,但是rand()被调用了多次,我不确定我是否可以通过足够的控制来装备它来测试我需要的东西。多次获取随机项目,并将实际比率与预期比率进行比较。但除非我可以无限次地运行它,否则这永远不会完美,并且如果我在RNG中运气不佳,可能会间歇性地

ruby-on-rails - 如何将 Ruby 变量放入正则表达式代码中

我正在运行grep方法以通过模式匹配进行过滤。这是示例代码。companies.grep/city/但是,ruby不允许我在railsView内的block中输入area_code。相反,我不得不像这样对其进行硬编码:companies.grep/miami/请记住,城市是一个变量。例如,city=miami但是,它会更新。你知道如何通过grep方法传递变量吗?此外,我尝试了companies.grep/#{city}/,但没有成功 最佳答案 companies.grep/#{city}/#orcompanies.grepRegex

ruby-on-rails - 来自 cucumber 的 HTTP POST XML 内容

我正在尝试通过POST将XML内容发送到一个简单的Rails项目中的Controller(“解析”)方法(“索引”)。它不是RESTful,因为我的模型名称不同,比如“汽车”。我在有效的功能测试中有以下内容:deftest_index...data_file_path=File.dirname(__FILE__)+'/../../app/views/layouts/index.xml.erb'message=ERB.new(File.read(data_file_path))xml_result=message.result(binding)doc=REXML::Document.ne

ruby - 在指定目录下创建文件

如何在特定目录中创建新文件。我创建了这个类:classFileManagerdefinitialize()enddefcreateFile(name,extension)returnFile.new(name我想指定创建文件的目录(路径)。如果这个不存在,他将被创建。所以我必须使用fileutils如图所示here在创建文件之后或者我可以在创建时直接指定创建文件的位置吗?谢谢 最佳答案 以下代码检查您传入的目录是否存在(使用File.dirname从路径中提取目录),如果不存在则创建它。然后它会像以前一样创建文件。require'f